package 剑指;

import java.util.Arrays;

/**
 * 从扑克牌中随机抽5张牌，判断是不是一个顺子，即这5张牌是不是连续的。2～10为数字本身，A为1，J为11，Q为12，K为13，而大、小王为 0 ，可以看成任意数字。A 不能视为 14。
 *
 *  
 *
 * 示例 1:
 *
 * 输入: [1,2,3,4,5]
 * 输出: True
 *  
 *
 * 示例 2:
 *
 * 输入: [0,0,1,2,5]
 * 输出: True
 *  
 *
 * 限制：
 *
 * 数组长度为 5 
 *
 * 数组的数取值为 [0, 13] .
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/bu-ke-pai-zhong-de-shun-zi-lcof
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
public class 扑克牌中的顺子 {

    public static boolean isStraight1(Integer[] nums) {
        if(nums == null || nums.length != 5) return false;
        Arrays.sort(nums, (Integer a, Integer b) -> { return a-b;});
        int anyNums = 0;
        int pre = 0;
        boolean flag = false;
        for(int i = 0; i < nums.length; i++){
            if(nums[i] != 0) flag = true;
            if(flag){

                if(pre != 0){
                    if(nums[i]-pre == 0) return false;
                    anyNums -= (nums[i]-pre)-1;
                }
                pre = nums[i];
            }else{
                anyNums ++;
            }
            if(anyNums < 0) return false;
        }
        return true;
    }

    public static boolean isStraight(int[] nums) {
        return isStraight1(Arrays.stream(nums).boxed().toArray(Integer[]::new));
    }
}
